package com.wing.bill.controller.admin;

import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.wing.bill.model.entity.BillOrdInformation;
import com.wing.bill.service.BillOrdInformationService;
import com.wing.common.utils.LocalDateTimeUtils;
import com.wing.common.utils.PageResult;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import lombok.RequiredArgsConstructor;
import org.apache.commons.lang.StringUtils;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.time.LocalDateTime;

@Validated
@Api(value = "Admin-账单表账单汇总管理,回收账单展示", tags = "#/bill/billOrdRecycleInformation")
@RestController("billOrdRecycleInformationController")
@RequestMapping("bill/admin/billOrdRecycleInformation")
@RequiredArgsConstructor
public class BillOrdRecycleInformationController {
    private final BillOrdInformationService billOrdInformationService;


    @ApiOperation(value = "查询所有领新账单表账单汇总", notes = "搜索")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "page", value = "第几页", defaultValue = "1", example = "1", dataType = "Integer", paramType = "query")
            ,@ApiImplicitParam(name = "limit", value = "每页多少条", defaultValue = "10", example = "10", dataType = "Integer", paramType = "query")
            ,@ApiImplicitParam(name = "sort", value="排序字段名", defaultValue = "create_time", example = "create_time", dataType = "String", paramType = "query")
            ,@ApiImplicitParam(name = "order", value="排序规则(asc:正序, desc:倒序)", defaultValue = "desc", example = "asc", dataType = "String", paramType = "query")
            ,@ApiImplicitParam(name = "billNo", value="账单编码", defaultValue = "", example = "", dataType = "String", paramType = "query")
            ,@ApiImplicitParam(name = "startTime", value="账单开始时间", defaultValue = "", example = "", dataType = "String", paramType = "query")
            ,@ApiImplicitParam(name = "endTime", value="账单结束时间", defaultValue = "", example = "", dataType = "String", paramType = "query")
    })
    @GetMapping("/list")
    public PageResult<BillOrdInformation> list(
            @RequestParam(defaultValue = "1") Integer page
            ,@RequestParam(defaultValue = "10") Integer limit
            ,@RequestParam(defaultValue = "create_time") String sort
            ,@RequestParam(defaultValue = "desc") String order
            ,String billNo
            ,String startTime
            ,String endTime
    ){

        Page<BillOrdInformation> pg = new Page<>(page, limit);
        QueryWrapper<BillOrdInformation> queryWrapper = new QueryWrapper<>();

        //排序
        if (StringUtils.isNotBlank(sort) && StringUtils.isNotBlank(order)) {
            if (StringUtils.equals("asc", order)) {
                queryWrapper.orderByAsc(StrUtil.toUnderlineCase(sort));
            } else {
                queryWrapper.orderByDesc(StrUtil.toUnderlineCase(sort));
            }
        }

        //搜索
        if (StringUtils.isNotBlank(billNo)) {
            queryWrapper.like("bill_no", billNo);
        }
        if (StringUtils.isNotBlank(startTime)) {
            LocalDateTime start = LocalDateTimeUtils.convertStringToLDT(startTime,"yyyy-MM-dd");
            queryWrapper.ge("start_time", start);
        }
        if (StringUtils.isNotBlank(endTime)) {
            LocalDateTime end = LocalDateTimeUtils.convertStringToLDT(endTime,"yyyy-MM-dd");
            queryWrapper.le("end_time", end);
        }

        queryWrapper.eq("type",BillOrdInformation.Type.recycle.getValue());


        IPage<BillOrdInformation> list = billOrdInformationService.getBaseMapper().selectPage(pg, queryWrapper);
        return new PageResult<>(list.getRecords(), list.getTotal());
    }
}
